public class ValidatePalindromeString {

    //给定一个字符串，验证它是否为回文串，只考虑字母和数字字符，可以忽略字母大小写
    public boolean isPalindrome(String s) {
        if (s.length() == 0) {
            return true;
        }
        //左右指针
        int l = 0, r = s.length() - 1;
        while (l < r) {
            //从头和尾向中间遍历
            if (!Character.isLetterOrDigit(s.charAt(l))) { //字符不是字母和数字的情况 -- 空格和特殊字符
                l++;
            } else if (!Character.isLetterOrDigit(s.charAt(r))) {  //字符不是字母和数字的情况
                r--;
            } else {
                //判断两者是否相等
                if (Character.toLowerCase(s.charAt(l)) != Character.toLowerCase(s.charAt(r))) {
                    //不等就不是回文
                    return false;
                }
                //等才会继续递增递减
                l++;
                r--;
            }
        }
        return true;
    }
}
